Patent Number:

JP63217452

Publication date:

1988-09-09

Inventor(s):

SAITO TAKASHI

Applicant(s)::

MITSUBISHI ELECTRIC CORP

Requested Patent:

□ JP63217452

Application Number: JP19870051509 19870306 Priority Number(s):

IPC Classification:

G06F12/16; G11C7/00; G11C11/34; G11C29/00

EC Classification:

Equivalents:

#### Abstract

PURPOSE:To automatically set the access timing of a memory by changing successively the set value of a register by a program and giving an access to memory based on the set value obtained when the coincidence of comparison is obtained between read data and write data. CONSTITUTION:An optimum value is set at each of registers 21-24 and a memory (RAM 1) receives an access based on each set value of these registers to write and read the test data. These test write and access based on each set value of these registers to write and read data are compared with each other for each access action carried out based on each set value. When read data are compared with each other for each access action carried out based on each set value is set the coincidence is obtained between write and read data of the memory (RAM 1) the relevant value is set tread data are compared with each other for each access addon carried out based on each set value. When the coincidence is obtained between write and read data of the memory (RAM 1), the relevant value is set at the registers 21-24 respectively as the final set value. Then the access timing is decided based on said final set value and the memory (RAM 1) receives accesses in this timing for prescribed data writing and final set value and the memory (RAM 1) receives accesses in this timing for prescribed data writing and reading constitute. In such a way, the access timing of the RAM can be automatically set with no reading operations. In such a way, the access timing of the RAM can be automatically set with no intervention of man power.

19日本国特許厅(JP)

① 特許出額公開

## ®公開特許公報(A) 昭63-217452

| Gijint, Ci.                 | D-100 - | 庁内整理番号                                                       |      | 砂公開 | 昭和63年(196 | 8)9月9日 |  |
|-----------------------------|---------|--------------------------------------------------------------|------|-----|-----------|--------|--|
| G 06 F 12/16<br>G 11 C 7/00 | 3 1 3   | A - 7737 - 5B<br>7341 - 5B<br>A - 8522 - 5B<br>H - 7737 - 5B | 等在請求 | 未請求 | 発明の数 1    | (全8頁)  |  |

図発明の名称

メモリアクセスタイミング設定方式

頭 昭62-51509 ②特

图 昭62(1987)3月6日 会出

砂発 明 者

神奈川県鎌倉市上町量325番地 三菱電磁株式会社計算機

製作所內

三菱電機株式会社 ⑪出 瞬 人

東京都千代田区丸の内2丁目2番3号

外2名 弁理士 大岩 増雄

ノモリアクセスタイミング設定方式

### 2. 特許請求の範囲

メモリのアクセスを行う論理目路において、ブ ログラムによって任意に値を設定できるレジスタ を設け、このレジスタへの設定値をプログラムに よって現々に変えでゆき、メモリへのテストデー タの書き込み、読出し、書込みデータと読出しデ - タとの比較を繰り返して行い、比較の結果が一 及した時の設定値モレジスタに設定しておき、こ の設定値に基づいてメモリのアクセスを行うこと を特徴とするメモリアクセスタイミング設定方式。

### 1 発明の評解な政明

### (産業上の利用分野)

この発明はデータ処理装置などに備えられるう ンダムアクセスメモリ (以下RAMと称す) の7 クセスタイミングを設定するためのメモリアクセ スタイミング設定方式に関するものである。

(従来の技術)

第6回は従来のメモリアクセスタイミング設定 方式を採用した論理団器のブロック図である。図 において、1はRAM(ダイナミックRAMを用 いた場合を例にとる)、2はアドレスマルチプレ クサ、3はRAN1とアドレスマルチプレクサ2 とを接続するマルテプレクスド・アドレス・パス、 4 はフドレスマルチプレクサ2に接続されるアド レスパス、 5 はR A M l に接続されるデータパス、 6 はノモリ制御リングである。また、1はローア ドレスセレクト信号(RAS信号)生成用のフリ ップフロップ(BTRAS用フリップフロップと 称す)、8はカラムアドレスセレクト信号(CA Sは号)生成用のフリップフロップ(以下CAS 用フリップフロップと称す)、9はカラムセレク トは号(COLSは号)生成用のフリップフロッ プ(以下COLS用フリップフロップと称す)、 10 HANDY - 1. 11, 12, 13 HORY -1. 14. 15. 16 UNORY-1. 17. 18.19.20はメモリ制御リング6のどの出 力を使用するかを選択するためのジャンパ線であ る。なお、既明を簡単にするためR人MIのリフ レッシュ用の論理回路は省略する。

次に動作について益明す。説明の中で「1」は 有意もしくはハイレベルを、「0」は非有意もし くはローレベルを言葉する。メモリ制御リング 6 はラインししのメモリアクセスモード信号が「1」 になるとイネーブルされて動作可能状態となり、 ラインしての基本クロックに同期して出力T C. T1, ..., Tk, ..., TZ, .... Tm. . . . . Tn. . . . , Te-1. Te # それぞれ単に「1」になるという形で状態が連移 する。また、ノモリアクセスモード信号が「0」 になると、メモリ製御リング6の出力T0~Te は全て「0」になる。各フリップフロップ?、8. 9はラッチした信号を各出力縄子!から出力し、 そのラッチした信号の反転信号を各出力端子りか ら出力する。RAM1の箱子RAS、CAS. WEにそれぞれ与えられるRAS信号。CAS信 号。WE信号は「1」で有寒とする。またいこの 従来例の場合、ジャンパ雑17、18、19。

20の設定は人手により行い、ノモリ制御リング 6の出力Tk、Tt. Tm. Tnがそれぞれ選択 されたものとする。

ここで来る図に示すタイミングチャートを愛報してRAM1への書込み動作を例にとって設明する。メモリアクセスが開始されると、ラインし1のティトモード信号が「1」になる。この時、アドレスがアドレスバスもに与えられ、アドレスがではよりローアドレスが選択されてアルチプレクスド・アドレス・バス3上に出力される。またられる。

このようなローアドレス及び書込みデータが与えられ、ノモリ制御リング6は前述したようにラインし1のメモリアクセスモード信号が「1」になっているので動作を開始し、出力下Q、T1・・・・ Tkが順次「1」になるという形で状態が選移する。そして出力Tkが「1」になると、メンパ線17及びORゲート11を経由してRA

S用フリップフロップ1の柚子口に「~」の出力 丁kが与えられ、ノモリ制御リング6の出力Tk + lが「l」になる時、RAS用フリップフロッ プ1の出力確子!から出力されるRAS信号が 「1」になる。また、この時、RAS用フリップ フロップ 7 の出力 4子 0 から出力される反転出力 は「0」となり、これによりNORゲート14の 出力が「1」、ORゲート11の出力が「1」と なって、メモリ制御リング6の状態が進んでも RAS用フリップフロップ1の出力、すなわち RAS信号は「1」にホールドされる。また、メ モリ制御リング6の「1」の出力がT8からT8 ↑1に連移した時、前記と同様な動作によりCO LS用フリップフロップ3の出力であるCOLS 信号が「1」になりホールドされる。このCOL Sは号により、アドレスマチブレクサ2はマルチ プレクスド・アドレス・パスろにカラムフドレス を出力し、また、ANDゲートI0の出力、すな わちRAM1の箱子WEに与えられるWE信号が 「1」となり、RAM1はライトモードとなる。

また、メモリ制御リング6の「1」の出力がTm からTm+1に通移した時、胸紀と同様な動作に よりCAS用フリップフロップ8の出力、すなわ ちCASは号は「L」になりホールドされる。以 上のようにRAS信号、CAS信号、WE信号、 COLS健寺が全て「!」となって、RAM1へ の書込み条件が全て掛い、データの書込み動作が 行われ、メモリ制造リング6の状態が進み、出力 Tn-1か「1」になった時点で書込み動作が発 アナる。メモリ制御リング6の出力Ta、すなわ ちラインし4のメモリアクセス完了信号が「1」 になり、次に出力Tロ+1か「1」になろうとす るところでラインレーのメモリアクセスモード値 号及びラインL3のライトモード信号が「0」に なり、また、NORゲート14.15,16及び ORゲート11、12、13の出力が「0」にな るので、RAS信号、CAS信号、COLS信号 が「O」になり、RAMIへの書込み動作が終了 する。なお、気4因に示すTWは、RAM1への 制御信号(メモリアクセスモード信号、ライトモ ード信号、RAS信号、COLS信号、CAS信号WE信号)によるライトモード条件成立期間である。

### {免明が解決しようとする問題点]"

従来のメモリアクセスタイミング設定方式においては、RAMへのアクセスタイミングを決定する部分がジャンパ誌による設定であったため、モ

のジャンパ語のR A Mのではない、一般にはは、A Mのでは、なり、というなどのでは、A Mのでは、A Mのでは、A Mのでは、A Mのでは、A Mのでは、A Mを使用する。というない。なり、A Mを使用する。というない。ないでは、A Mを使用する。というない。ないでは、A Mを使用される。のは、A Mを使用されている。のは、A Mを使用されている。のは、A Mを使用されている。のはないである。のはなどである。のはなどである。のはなどである。のはなどである。のはなどである。のはなどである。と、A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M を C A M

この発明は上記のような問題点を解析するためになされたもので、RAMのアクセスタイミングの設定を人手の介入なしに自動的に行い、RAMの性能を十分に引き出すことができ、位領性を向上させることができるメモリアクセスタイミング設定方式を提供することを目的とする。

### (問題点を解決するための手段)

この発明に振るメモリアクセスタイミング設定 方式は、メモリ (RAM1) のアクセスを行う論 理回路において、プログラムによって任意に値を

設定できるレジスタ 2 1 . 2 2 . 2 3 . 2 4 を設け、このレジスタ 2 1 . 2 2 . 2 3 . 2 4 へのかったによって増々に変えてゆき、はせい。 まい (R A M 1) へのチストデータの自込かを受け、 はいのないが、 はいのないが、 はいのないが、 はいのないが、 はいのないが、 2 2 1 . 2 2 . 2 3 . 2 4 に設定しておき、の設定値に基づいてメモリ(R A M 1)のアクセスを行うことを特徴とするものである。

#### (作用)

この発明に係るレジスタ21、22、23、24にはプログラムによって任意の値が設定され、メモリ(RAM1)は設定された各設定値に基づいてアクセスされ、テナデータの書込みデータとは各設定値に基づいたアクセストデータの書込みデータとは各設には、メモリ(RAM1)の書込みデータと映出しデータとか一致した時、その値に基礎の設定値に基づいたの最終の設定値に基づい

てアクセスタイミングが決められ、メモリ (RAMI) はそのアクセスタイミングでアクセスされ、 所足のデータの書込み、提出し動作を行う。

#### (発明の実施例)

以下この発明の一実施例を図に基づいて説明す る。狭1回はこの発明の一実施例に係るメモリア クセスタイミング設定方式を提用した論理団路の ブロック国である。第1回において、第6回に示 丁禄成要常に対応するものには同一の参照符を付 し、その説明を省略する。第1回において、21 はRAS信号生成タイミングを決めるためのレジ スク(以下RAS用レジスタと称す)、 22は COLS信号生成タイミングを決めるためのレジ スク(以下COLS用レジスタ)、23はCAS 信号生成タイミングを決めるためのレシスタ(以 下CAS用レジスタと称す)、24はメモリアク セス完了信号生成タイミングを決めるためのレジ スタ(以下CPT用レジスタと称す)、25. 26. 27. 28はメモリ関調リング6のヒ+1 個ある出力T0~Teの内の1個を選択して出力 するセレクタである。

次に動作について説明する。入手できたRAMが例えば5種類あり、そのRAMをアクセスタイムが違い域にRAM』、RAM』、RAM』、RAM』は日本の各RAMに対しては第2図のタイミング図に示すようにRAMに対しては第2図のタイミング図に示すようにRAMのアクセスは合うによりませる。以下の説明はRAM』が実験された場合の動作を考える。

プログラムは、RAS用レジスタ21、COLS用レジスタ22、CAS用レジスタ23、CPして用レジスタ24への設定値、すなわち第2回に対応する設定値は1~k5、41~45、m1~m5、n1~a5をテーブルとして持っている。このプログラムは第3回に示すフローチャートを実行する。すなわち、プログラムが実行され(ステップS1)、ポインタはRAM,を存存しての場合第2回に示すRAM,に対応する設定値は1)

そRAS用レジスタ21にロードする (スチップ S3)、次にそのポインタの内容をインクリメン トレ (ステップS4) 、ポインタの示す内容 (こ の場合RAM。に対応する設定値をし) そCOL S用レジスタ22にロードする (ステップS5) 次にそのポインタの内容をインクリメントし(ス テップS6)、ポインタの示す内容(この場合 RAM,に対応する設定値ml)をCAS用レジ スタ23にロードする(ステップS7)。 次にも のポインタの内容をインクリメントし(ステップ S8)、ポインタの示す内容(この場合RAM) に対応する設定値ヵ1)をCPLT用レジスタ 24にロードする(ステップS9)。 次にそのポ インタの内容をインクリメントしておき(ステッ プS!3)、テストデータモRAMェ (この場合 RAM。が実装されているので)に書込みを行う (ステップS11)。この書込みは第4回に示す タイミングで行われる。また、RAM。からは焦 5 国に示すタイミングでデータが決出され(ステ ップS12)、彼出しデータと書込みデータとが

比較される(ステップS13)。この場合、設定値はRAM。に対応する設定値 k 1。 e 1。 m 1。 n 1 であり、RAM。に対じては調御信号(RAS信号、COLS信号、CAS信号、メモリアクセス完丁信号)のタイミングが適合しないたか、ステップS13での検出しデータと書込みデータとはそのタイミングにおいては等しくならない。従って、ステップS14に移りポインタがエラーか否かを判断し、エラーであるときはエラー報告し(ステップS15)、エラーでないときはステップS3に戻る。

このステップS3に買ったときのポインタの記言語されているRAM。に対応する公司に対しているRAM。に対応するASRAO豆はは、2がRASRレジスタ21にロードされる。その後は、胸はな処理を行い(ステップS4~S10)、設定値m2がCAS用レジスタ23に、設定値m2がCPLT用レジスタ24にそれぞれロードされ、テストデータのRAM。への書込み(ステップ

S I I )、R A M 。からのデータ統出し(ステッ プSI2)を行い、読出しデータと書込みデータ とが比較される(ステップS13)。この場合は、 設定値k 2、 & 2、 m 2、 n 2 が R A M 。 に対応 しているのでRAM。は所定のタイミングでアク セスされ、従って、説出しデータと書込みデータ とが等しくなり、ステップS16に移り設定値 k 2、 f 2、 m 2、 n 2が各レジスタ21、 2.2、 23.24への最終の設定値として設定され、セ レクタ25、26、27、28によってメモリ新 御リング6の出力T k 2 + 1 が「l 」の時にRA S信号が、出力T&2 + 1 が「1」の時にCOL S信号が、出力Tm2+lが「1」の時にCAS 信号が、出力で n 2 が「1」の時にメモリアクセ ス克丁信号がそれぞれ「1」になり、また、出力 Tn2+1が「1」の時にRAS信号、COLS 信号、CAS信号、メモリアクセス充了信号がそ れぞれ「0」になるというRAMアクセズタイミ ングが設定され、所定のデータの審込み、設出し 動作が行われる。

なお、このフローチャートの説明はRAM。が 実装されている場合について述べたが、実装され ているRAMが、RAM。、RAM。、RAM。 RAM。のときはステップS3~S13の処理は 一回、3回、4回、5回それぞれ行われ、アクセ スタイミングが設定される。

 なお、上記実施例においてはRAMとしてダイナミックRAMを用いた場合を示したが、スタティクRAMを用いた場合にはRASは号及びCASは号の代わりにチップセレクトは号(COEは号)を製御するようにすればよい。また、上記実施例ではメモリ刺御リングを用いてRAMアクセスタイミングを製御したが、データロードの可能なカウ

ンタと、カウンタに初別値としてロードする値を 設定するレジスタの組合わせをプログラム制御し たい信号毎に設けることによっても本発明の方式 は実現できる。

#### (発明の効果)

が設定のための人手の介入が不必要となり、これにより動作試験費あるいは人権費が削減でき、より安価なデータ処理装置などを提供することができるという効果が得られる。

#### 4. 図面の簡単な設务

1 · · · R A M (メモリ) 、2 · · · アドレス マルチプレクサ、6 · · · メモリ制力リング、7 · · · R A S 用フリップフロップ、8 · · · C A

#### 特開昭63-217452(6)

S 用フリップフロップ、 9 · · · C O L S 用フリップフロップ、 1 0 · · · A N D ゲート、 1 l · · · 1 2 · · 1 3 · · · O R ゲート、 1 4 · · 1 5 · · 1 6 · · · · N O R ゲート、 2 1 · · · · R A S 用レジスタ、 2 2 · · · · C O L S 用レジスタ。 2 3 · · · C A S 用レジスタ、 2 4 · · · · C P L T 用レジスク、 2 5 · · 2 6 · · 2 7 · · 2 8 · · · · セレクタ。

代理人 大 岩 増 雄(ほか2名)



第2回

| RAM  | RISA  | <u> </u> | AS L  | 7. DE |     | 1711 |     | 650 |
|------|-------|----------|-------|-------|-----|------|-----|-----|
| DAM. | 74.27 | Terri    | Imiei | Tnı   | \$1 | 2    | 9   | n   |
| DAM  | 742+1 | Te2-1    | Ĩπ2+1 | Tnz   | #2  | 12   | m 2 | n 2 |
| RAM  | Tool  | Tegel    | Ing-1 | Tng   | 43  | 13   | W)  | 03  |
| PAMe | 744-1 | Tes+1    | Tree! | Tna   | Ŕ.  | 2ª   | m 4 | n4  |
| 0444 | 744.4 | 705.01   | Ims+I | Tris  | 165 | 25   | m5  | 15  |



第4回



### 第5团



第6团



Japan Patent Office (JP) (19)

Patent Application Disclosure (11)

Unexamined Patent Application Publication (A) S63-217452 (12)

| (51) Int. Cl. <sup>4</sup> G 06 F 12/16 G 11 C 7/00 11/34 29/00 | Identification No. 310 313 371 303 | File No.<br>A-7737-5B<br>7341-5B<br>A-8522-5B<br>H-7737-5B |
|-----------------------------------------------------------------|------------------------------------|------------------------------------------------------------|
| 29/00                                                           | <del>-</del> -                     |                                                            |

Disclosure Date: September 9, 1988 (43)

No examination requested

Number of inventions: 1 (Total of 8 pages)

Name of Invention: Method for Setting Memory Access Timing (54)

Patent Application S62-51509 (21)

Application Date: March 6, 1987 (22)

Takashi Saito Inventor: (72)

Mitsubishi Electric Company, Ltd., Computer Manufacturing

**Facilities** 

325 Uemachiya, Kamakura City, Kanagawa Prefecture

Mitsubishi Electric Company, Ltd. Applicant: (71)

2-2-3 Marunouchi, Chiyoda-ku, Tokyo

Masao Oiwa, Patent Attorney, and two others Representative: (74)

#### **Details**

Name of Invention 1. Method for Setting Memory Access Timing

#### Patent Claims 2.

A method for setting memory access timing in a logical circuit that accesses memory, characterized by the provision of a register for which a variety of values can be set by a program, by repetitively having the value set in said register be changed sequentially by the program and performing test writes to the memory and test reads from the memory where the data that is written is compared to the data that is read, by setting to the register the setting that was in effect when the results of the comparison matched, and by accessing the memory based on said setting.

### Detailed Explanation of the Invention

### [Area of Application in Industry]

This invention pertains to a method for setting the memory access timing in order to set the access timing for random access memory (hereinafter abbreviated "RAM") that is equipped in, for example, data processing devices.

### [Prior Art]

Figure 6 shows a block diagram of the logic circuits that use the conventional memory access timing set method. In the figure, 1 is RAM (using the example where a dynamic RAM is used), 2 is an address multiplexer, 3 is a multiplexed address bus connecting the RAM 1 with the address multiplexer 2, 4 is an address bus connected to the address multiplexer 2, 5 is a data bus connected to the RAM 1, and 6 is a memory control ring. In addition, 7 is a flipflop for generating the row address select signal (RAS signal), hereinafter abbreviated "RAS flipflop," 8 is a flipflop for generating the column address select signal (CAS signal), hereinafter abbreviated "CAS flipflop," 9 is a flipflop for generating the column select signal (COLS signal), hereinafter abbreviated "COLS flipflop," 10 is an AND gate, 11, 12, and 13 are OR gates, 14, 15, and 16 are NOR gates, and 17, 18, 19, and 20 are jumper lines for selecting the output from the memory control ring 6 that is to be used. Additionally, for simplicity in the explanation, the logic circuits for refreshing the RAM 1 are not shown.

The operation of this method is described below. In this explanation, "1" indicates either the active level or the high logic level, while "0" indicates the inactive level or the low logic level. The memory control ring 6 is enabled and placed in an operational state when the memory access mode signal of line L1 goes to "1," and, synchronized to the master clock on line L2, the outputs T0, T1, ..., Tk, ..., T1, ..., Te-1, Te are sequentially set to "1" in the state transitions. When the memory access mode signal is "0," all outputs T0 to Te from the memory control ring 6 go to "0." The respective flipflops 7, 8, and 9 each output their latched signals from the output terminal 1 on each, and output the inverse of the latched signal on output terminal 0 of each. The RAS signal, CAS signal, and WE signal applied, respectively, to the RAS, CAS, and WE terminals of RAM 1 are each active at "1." In addition, in this conventional example, jumper lines 17, 18, 19, and 20 are set by hand, selecting, respectively, outputs Tk, Tl, Tm, and Tn of the memory control ring 6.

Below will be explained an example of an operation to write to the RAM 1, referencing the timing chart shown in Figure 4. When the memory access commences, both the memory access mode signal on Line L1 and the write mode signal on Line 3 both go to "1." At this time, the address is applied to the address bus 4, the row address is selected by the address multiplexer 2 and is output on the multiplexed address bus 3. At this time the write data is applied to data bus 5.

In this way, the row address and write data are applied, and, as described above, the memory access mode signal of line L1 is at "1," so the memory control ring 6 commences operations, and there are state transitions so that outputs T0, T1, ... Tk sequentially go to "1." When Tk goes to "1," the "1" output Tk is applied to terminal D of the RAS flipflop 7 through the jumper line 17 and OR gate 11, and when output Tk + 1 of memory control ring 6 goes to "1," the RAS signal that is output from output terminal 1 of the RAS flipflop 7 goes to "1." In addition, at this time the inverted signal that is output from the output terminal 0 of the RAS flipflop 7 goes to "0," causing the output of the NOR gate 14 to go to "1," and the output of the OR gate 11 to go to "1," causing the output of the RAS flipflop 7, or in other words the RAS signal, to be held at "1" even if the memory control ring 6 status advances. When the "1" output of the memory control ring 6 transitions from TI to TI + 1, the same operation as described above causes the COLS signal, which is the output of the COLS flipflop 9, to be held at "1." This COLS signal causes the address multiplexer 2 to output the column address to the multiplexed address bus 3, and the output of the AND gate 10, or in other words the WE signal that is applied to the RAM 1 terminal WE, goes to "1," placing RAM 1 in write mode. When the "1" output of the memory control ring 6 transitions from Tm to Tm + 1, a operation similar to what was described above causes the output of the CAS flipflop 8, or in other words the CAS signal, to be held at "1." As described above, the RAS signal, the CAS signal, the WE signal, and the COLS signal all go to "1," putting all conditions in place to write to the RAM 1; hence the data write operation is performed, the status of the memory control ring 6 advances, and the write operation is concluded at the point in time where the output Tn - 1 goes to "1." When the output Tn of the memory control ring 6, or in other words the memory access complete signal on line 4, goes to "1" followed by the output Tn + 1 going to "1," the memory access mode signal on line L1 and the write mode signal on line L3 both go to "0," causing the outputs of the NOR gates 14, 15, and 16, along with the outputs of the OR gates 11, 12, and 13 to go to "0"; consequently, the RAS signal, the CAS signal, and the COLS signal all go to "0," completing the operation for writing to the RAM 1. Note that TW shown in Figure 4 is the period over which the write mode conditions are fulfilled by the control signals to the RAM 1 (i.e., the memory access mode signal, the write mode signal, the RAS signal, the COLS signal, the CAS signal, and the WE signal).

On the other hand, in the operations to read from the RAM 1, as shown in Figure 5, the write mode signal and the WE signal go to "0," and at the point in time when the output Tn - 1 of the memory control ring 6 ceases to output "1," or in other words, at the point in time when the output Tn goes to "1," the output data that is read from the RAM 1 is assumed to be set, and with the output Tn, the data on the data bus 5 is accepted. At this time, when, in operations similar to the write operations described above the output Tn + 1 of the memory control ring 6 is to go to "1," all control signals become inactive and the operations to read from the

RAM 1 are terminated. Note that the TR shown in Figure 5 is the period of time over which the control signals to the RAM 1 fulfill the read mode conditions.

### [Problems Solved by this Invention]

In the conventional method for setting the memory access timing, the part that sets the RAM access timing is set by jumper lines, and thus it requires a manual intervention to set the jumper lines. Additionally, generally RAMs have a variety of different access times, and when the type of RAM that is used is changed it is necessary to change the settings of the jumpers in order to change the access timing, and, as a result, the RAM cannot be accessed correctly if the setting is incorrect or there may also be the problem that, even if RAM that can operate at high speeds is used, the actual performance of the RAM will not be good if the access timing used is for low speed RAM.

This invention was created in order to solve the types of problems described above, and its objective is to provide a method of setting the memory access timing that automatically sets the access timing without any manual intervention, making it possible to exploit the full capabilities of the RAM and to improve reliability.

### [Method by Which the Problems are Solved]

The method of setting the memory access timing in this invention is characterized by the logic circuits that access the memory (RAM 1) being equipped with registers 21, 22, 23, and 24 that can be set to a variety of values by a program, where the values that are set to these registers 21, 22, 23, and 24 are repetitively changed sequentially by the program at which time test data is written to and read from the memory (RAM 1) and comparisons are made between the write data and the read data where the values that were set when the results of the comparison indicates a match are set to registers 21, 22, 23, and 24, so that the access to the memory (RAM 1) is performed based on these settings.

### [Operation]

The registers 21, 22, 23, and 24 in this invention are set to any given value by the program, and the memory (RAM 1) is accessed based on the various settings that have been set, at which time test data is written to the memory and read from the memory. The data written as this test data, and the data that is read, are compared to each other for each of the access operations that are based on the respective settings, and when the data that is written to the memory (RAM 1) matches the data that is read from the memory, then the settings are set as the final settings in the registers 21, 22, 23, and 24, and after that time the access timing is determined based on these final settings and the memory (RAM 1) is accessed with that access timing when the specific data write and data read operations are performed.

### [Example of Embodiment]

An Example of Embodiment of this invention is explained below based on the figures. Figure 1 is a block diagram of logic circuits that use the method for setting the memory access timing in this Embodiment of the invention. In Figure 1 the same symbols are used as corresponding to the structural elements shown in Figure 6, so the explanations are omitted here. In Figure 1, 21 is the register for determining the timing with which the RAS signal is produced (hereinafter termed the "RAS register"), 22 is the register for determining the timing with which the COLS signal is produced (hereinafter termed the "COLS register"), 23 is the register for determining the timing with which the CAS signal is produced (hereinafter termed the "CAS register"), 24 is the register for determining the timing with which the memory access complete signal will be produced (hereinafter termed the "CPLT register"), 25, 26, 27, and 28 are the selectors that select one output from output T0 to Te of the e + 1 registers in memory control ring 6.

Next the operation will be explained. Let us assume that there are five different types of RAM that can be obtained, and, the access timing on these types of RAM, from fastest to slowest, are RAM<sub>1</sub>, RAM<sub>2</sub>, RAM<sub>3</sub> RAM<sub>4</sub>, and RAM<sub>5</sub>. The respective RAMs can be accessed correctly by outputting the RAS signals, COLS signals, CAS signals, and memory access complete signals shown in the timing diagram of Figure 2. The explanation described below considers the operations when RAM<sub>2</sub> is installed.

The table has the settings for the RAS register 21, the COLS register 22, the CAS register 23, and the CPLT register 24, or in other words, the settings for k1 to k5, 11 to 15, m1 to m5, and m1 to m5 in Figure 2, are stored as a table. This program executes the flow chart shown in Figure 3. In other words, the program is executed (Step S1), the pointer indicates RAM1 (Step S2), the information indicated by the pointer (in this case, the settings k1 corresponding to RAM1 shown in Figure 2) are loaded into RAS register 21 (Step S3), the pointer is then incremented (Step S4), the information indicated by the pointer (in this case, the setting 11 corresponding to RAM<sub>1</sub>) is loaded into the COLS register 22 (Step S5), the pointer is incremented (Step S6), the information indicated by the pointer (in this case, the setting m1 corresponding to RAM1) is loaded into the CAS register 23 (Step S7), the pointer is incremented (Step S8), the information indicated by the pointer (in this case the setting n1 corresponding to RAM1) is loaded into the CPLT register 24 (Step S9), the pointer is incremented (Step S10), the test data is written into the RAM<sub>2</sub> (because in this case it is RAM<sub>2</sub> that is installed) (Step S11), and the write operation is performed with the timing shown in Figure 4. Then the data is read from the RAM2 with the timing shown in Figure 5 (Step S12), and the data that was read is compared to the data that was written (Step S13). In this case, the settings are the settings k1, 11, m1, and n1 that correspond to RAM<sub>1</sub>. These settings do not match the timing for the control signals (the RAS signal, the COLS signal, the CAS signal, and the memory access complete signal) for RAM2, so the comparison in Step 13 of the data that was read and the data that was written does not indicate a match with this timing. As a result, the program continues to Step S14, and a check is made for a pointer error. If there is an error then an error report is made (Step S15), and if there is no error, then the program returns to Step S3.

The information indicated by the pointer when the program returns to Step S3 is the setting k2 that corresponds to the RAM2 that is installed, and this setting k2 is loaded into the RAS register 21. After that, the same process that is described above is performed (Steps S4 through S10) and the setting 12 is loaded into the COLS register 22, the setting m2 is loaded into the CAS register 23, the setting n2 is loaded into the CPLT register 24, the test data is written to the RAM<sub>2</sub> (Step S11) the data is read from the RAM2 (Step S12), and the data that was written is compared to the data that was read (Step 13). In this case, the RAM access timing is set so that, when the operations for writing and reading the specified data are performed, the settings k2, l2, m2, and n2 correspond to RAM2, and thus RAM2 is accessed with the appropriate timing and the data that was read matches the data that was written so the program continues to Step 16 and the settings k2, g2, m2, and n2 are set into registers 21, 22, 23, and 24 as the final settings, and selectors 25, 26, 27, and 28 cause the RAS signal to be "1" when the output Tk2 + 1 of the memory control ring 6 is "1," the COLS signal to be "1" when the output Tl2 + 1 is "1," the CAS signal to be "1" when the output Tm2 + 1 is "1," and the memory access complete signal to be "1" when the output Tn2 is "1." In addition, when the output Tn2 + 1 is "1" the RAS signal, the COLS signal, the CAS signal and the memory access complete signal all go to "0."

While the explanation of the flow chart was based on the assumption that RAM 2 was installed, if RAM<sub>1</sub>, RAM<sub>3</sub>, RAM<sub>4</sub>, or RAM<sub>5</sub> were installed instead, the processes in Steps 3 through 13 would be performed once, three times, four times, or five times, respectively, to set the access timing.

Because in the Example of Embodiment described above, it is possible to change the access timing using a program, it is easy to perform RAM access timing margin tests. In addition, although the timing will be that for the type of RAM with the slowest access time, even if a mixture of RAMs with different access times are installed in the logic circuits, the RAM can still be accessed correctly. In addition, if in high-speed computers, the RAM access timing is set individually by the card unit or the bank unit of main memory, then even if the type of RAM is different on different card units or bank units, the timing can be performed to match the capability of the RAM, making it possible to prevent any impediments to performance by mixing types of RAM. Additionally, in the program that determines the settings, it is possible to set the access timing that is optimized for the RAM that is installed and that is able to fully exploit the capabilities of the RAM through selecting the optimal values through changing the settings in even finer increments, rather than determining the settings in such a way as to compensate for the minor timing differences between the various RAM manufacturing locations. If in the program access timing setting checks are

performed for all addresses of all RAM, then it is possible to identify the RAM that has errors even if different types of RAM (with different access times) are mixed.

Furthermore, in the Example of Embodiment described above, dynamic RAM was used as the example, when static RAM is used then the chip select (CS) signal and the output enable (OE) signal can be controlled instead of the RAS signal and the CAS signal. Although in the Example of Embodiment above a memory control ring was used to control the RAM access timing, the method of this invention can also be performed by establishing for each signal to be controlled by the program a combination of a counter into which data can be loaded and a register that sets the value that is loaded into the counter as the initial value.

### [Effects of the Invention]

Using the invention described above, it is possible to set the memory access timing automatically without a manual intervention because a register is provided wherein a variety of different values can be set by the program where the values that are set into this register are repetitively changed sequentially, test data is written to the memory and then read from the memory, and the data that was written is compared to the data that is read and the values that were set when the results of the comparison indicate a match are set to the register so that the memory is accessed based on those settings, it is able to prevent any disruptions to memory performance or situations where access cannot be performed normally due to incorrect settings in the access timing, making it possible to fully exploit the capabilities of the memory, and thus possible to obtain the effect of increased reliability; in addition, it is no longer necessary to have a manual intervention in order to set the access timing using jumper lines as it has been conventionally, thus making it possible to reduce operating test expenses and reduce labor expenses, and making it possible to provide data processing equipment less expensively.

### 4. Simple Explanation of Figures

Figure 1 is a block diagram of the logic circuits that use the method for setting the memory access timing in the Example of Embodiment of this invention.

Figure 2 is a timing diagram showing the relationship between the settings and the access timing in this Example of Embodiment.

Figure 3 is a flow chart used for explaining the operation of the Example of Embodiment.

Figure 4 is a timing chart for explaining a conventional example and explaining the operations for writing to the RAM in the Example of Embodiment thereof. Figure 5 is a timing chart for explaining the conventional example and for explaining the operations for reading from the RAM in an example thereof. Figure 6 is a block diagram of the logic circuits that use the conventional method of setting the memory access timing.

- RAM (memory) 1:
- Address multiplexer 2:
- Memory control ring 6:
- RAS flipflop **7**:
- CAS flipflop 8:
- COLS flipflop 9:
- AND gate 10:
- 11, 12, 13: OR gates
- NOR gates 14, 15, 16:
- RAS register 21:
- COLS register 22:
- CAS register 23:
- **CPLT** register 24:
- 25, 26, 27, 28: Selectors

Representative: Masao Oiwa, and two others

### Figure 1

- Memory access mode signal [L1]
- Fundamental clock [L2]
- Memory control ring [6]
- Register [21]
- Selector [25]
- Register [22]
- Selector [26]
- Register [23]
- Selector [27]
- Register [24]
- Selector [28]
- Memory access complete signal [L4]

RAS signal [Under 14]

CAS signal

Address multiplexer [2]

[Above 10] COLS signal

Write mode signal [L3]

### Figure 2

IINSERT TABLE

| Type of RAM | RAS<br>signal<br>timing | COLS<br>signal<br>timing | CAS<br>signal<br>timing | Memor<br>y<br>access<br>comple<br>te<br>signal<br>timing | Settings i<br>generation | for the regige the timing the timing | sters for | Registe |
|-------------|-------------------------|--------------------------|-------------------------|----------------------------------------------------------|--------------------------|--------------------------------------|-----------|---------|
|             |                         | ł                        | 1                       |                                                          | Registe                  | 100gibit                             | - Lucy    |         |

|                          | <br>r 21 | r 22 | r 23 | т 24 |
|--------------------------|----------|------|------|------|
| [see source for English] |          |      |      |      |

```
Figure 3
       Start
Sl
       Set pointer = PRAM 1
       Load the information indicated by the pointer into the RAS register
S2
S3
       Pointer = pointer + 1
       Load the information indicated by the pointer into the COLS register
S4
S5
       Pointer = pointer + 1
       Load the information indicated by the pointer into the CAS register
S6
S7
       Pointer = pointer + 1
       Load the information indicated by the pointer into the CPLT register
S8
S9
       Pointer = pointer + 1
S10
       Write test data to the RAM
S11
       Read test data from the RAM
S12
       Compare the read data to the write data
S13
       Is there a pointer error?
S14
       Error report
S15
       Settings complete
S16
Figure 4
Fundamental clock
 Memory access mode signal
 Write mode signal
 T0
 TI
 Tk
 Te
 Tm
 Tn (Memory access complete signal)
 RAS signal
 COLS signal
 CAS signal
 WE signal
 Figure 5
  Fundamental clock
  Memory access mode signal
  Write mode signal
  T0
  TI
  Tk
  Te
  Tm
  Tn (Memory access complete signal)
```

RAS signal COLS signal CAS signal WE signal

Figure 6
[L1] Memory access mode signal
[L2] Fundamental clock
[6] Memory control ring
[L4] Memory access complete signal
[Under L4] RAS signal
CAS signal
WE signal
[2] Address multiplexer
[Above 10] COLS signal
[L3] Write mode signal

# This Page is Inserted by IFW Indexing and Scanning Operations and is not part of the Official Record

### **BEST AVAILABLE IMAGES**

Defective images within this document are accurate representations of the original documents submitted by the applicant.

| Defects in the images include but are not limited to the items checked: | - |
|-------------------------------------------------------------------------|---|
| ☐ BLACK BORDERS                                                         |   |
| ☐ IMAGE CUT OFF AT TOP, BOTTOM OR SIDES                                 |   |
| ☐ FADED TEXT OR DRAWING                                                 |   |
| ☐ BLURRED OR ILLEGIBLE TEXT OR DRAWING                                  |   |
| ☐ SKEWED/SLANTED IMAGES                                                 |   |
| ☐ COLOR OR BLACK AND WHITE PHOTOGRAPHS                                  |   |
| ☐ GRAY SCALE DOCUMENTS                                                  |   |
| ☐ LINES OR MARKS ON ORIGINAL DOCUMENT                                   |   |
| ☐ REFERENCE(S) OR EXHIBIT(S) SUBMITTED ARE POOR QUALITY                 |   |
| ☐ OTHER:                                                                | _ |

# IMAGES ARE BEST AVAILABLE COPY.

As rescanning these documents will not correct the image problems checked, please do not report these problems to the IFW Image Problem Mailbox.